#include <stdio.h>
void init(int arr[][10], int n)
{
	for (int i = 0; i < n; i++)
	{
		for (int j = 0; j < n; j++)
		{
			scanf_s("%d", &arr[i][j]);
		}
	}
}
void print(int arr[][10], int n)
{
	for (int i = 0; i < n; i++)
	{
		for (int j = 0; j < n; j++)
		{
			printf("%d ", arr[i][j]);
		}
		printf("\n");
	}
}
void shang_sanjiao(int arr[][10], int n)
{
	int flag = 0;
	for (int i = 1; i < n; i++)
	{
		for (int j = 0; j < i; j++)
		{
			if (arr[i][j] != 0)
				flag++;
		}
	}
	if (flag == 0)
		printf("YES");
	else
		printf("NO");

}
int main()
{
	int n;
	scanf_s("%d", &n);
	int arr[10][10];
	init(arr, n);
	shang_sanjiao(arr, n);
	return 0;
}